草庐IT

c++ - Clang、std::next、libstdc++ 和 constexpr-ness

全部标签

c# - 在 C# 中编写 C++ std::reverse 等效项的最接近方法是什么?

reverseC++标准库中的算法等同于templatevoidreverse(BidirectionalIteratorfirst,BidirectionalIteratorlast){while((first!=last)&&(first!=--last)){std::iter_swap(first,last);++first;}}根据http://www.cplusplus.com/reference/algorithm/reverse/.我想用C#编写等价物:publicvoidReverse(Tfirst,Tlast){//...}首先,你如何传入两个对IEnumerator

c++ - std::function 参数列表和 typedef

我有一个类似这样的typedef:typedefstd::functionMyFunction;在我的代码中某处是这样使用的:MyFunctionfunc=[](intarg1,floatarg2){/*dosometing*/};问题是,每次我更改函数的参数数量(例如,我添加第三个参数chararg3)时,我都被迫在我使用MyFunction的所有代码中更新它(即使这些根本不使用参数。而且我懒得那样做。有没有办法从它的类型中获取std::function的参数列表?(我的意思是)这样函数创建看起来像那样?:MyFunctionfunc=[](MyFunction::args){/*d

c++ - std::future 或 std::shared_future 等待多线程

我有一个线程从容器中获取每个元素并向数据库发送上传请求。上传是同步完成的。容器中的元素是金融合约,它们可能有也可能没有与之关联的数据结构调用ticktable。现在,对于那些有ticktable的合约,我必须进行两次上传。1)首先将ticktable上传到db。db返回一个id。2)将id附加到契约(Contract)上,然后上传契约(Contract)。因此,例如,如果我循环遍历包含100个合约的容器,假设其中30个具有ticktable,其余70个没有。我想弄清楚std::future或std::shared_future是否适合这样的任务?我尝试通过将future与30个合约中的

c++ - 在常量表达式上下文中定义之前的嵌套 `constexpr` 函数调用

根据我从thisanswer收集到的信息,如果函数尚未声明,则constexpr函数的结果不是常量表达式。令我惊讶的是以下代码片段:constexprintf();constexprintg(){returnf();}constexprintf(){return42;}intmain(){constexprinti=g();returni;}这个编译没有问题并且可以工作。将f的定义移动到主触发器之后error:'constexprintf()'usedbeforeitsdefinition,如我所料。我认为它可以工作,因为f已在调用g之前定义,因此这两个调用都是常量表达式。为什么f()

c++ - 什么时候使用 std::unordered_map::emplace_hint?

我知道如何使用std::unordered_map::emplace,但如何使用emplace_hint?都不是cplusplus也不cppreference提供一组示例来说明我们如何知道将元素放在哪里。任何人都可以提供一些这方面的信息或提供一些示例/说明,说明我们什么时候可以知道放置的元素应该放在哪里吗? 最佳答案 unordered_map可以做什么可能与提示有关吗?好吧,如果迭代器使用与emplace_hint的元素相同的键来寻址一个元素。已被要求插入,然后它可能会很快失败-只是一个键比较,没有任何散列或在该桶中的任何散列冲突

python - 为什么不能使用 std::ref 将对象传递到 Boost.Python 模块中?

环境:使用Python3.5编译的Boost1.61.0以下C++代码输出12:classA{public:intfunc(){return12;}};BOOST_PYTHON_MODULE(bridge){usingnamespaceboost::python;class_("A",no_init).def("func",&A::func);}intmain(){Aa;PyImport_AppendInittab("bridge",PyInit_bridge);Py_Initialize();usingnamespaceboost::python;dictdictMain=extra

c++ - std::thread 在使用参数创建时抛出访问冲突异常?

关闭。这个问题需要debuggingdetails.它目前不接受答案。编辑问题以包含desiredbehavior,aspecificproblemorerror,andtheshortestcodenecessarytoreproducetheproblem.这将有助于其他人回答问题。关闭6年前。Improvethisquestion我正在使用VS2015,在使用std::thread时遇到一个非常奇怪的问题。voidKlass::myfunc(inta,intb){std::cout它在Debug模式下运行良好,但当我转到Release模式时抛出“访问冲突异常”。此外,如果我尝试将

c++ - 为什么 clang 输出对齐特定的东西

假设我有一个基本的c程序,我用clang编译它,如下所示:#include"stdio.h"intx=0x7FFFFFFF;intmain(void){printf("%d\n",x);}使用clang-emit-llvmtemp.c-fno-rtti-O3-S编译生成以下位码:;ModuleID='temp.c'targetdatalayout="e-m:e-p:32:32-f64:32:64-f80:32-n8:16:32-S128"targettriple="i686-pc-linux-gnu"@x=globali322147483647,align4@.str=privateu

c++ - 一个尾数下标的明显规范不足:对于原始数组和 std::vector。已经果断解决了吗?

它以前曾以各种形式被问过,但由于语言规范在这方面似乎是动态的(或者至少是当一些关于这个问题的SO讨论发生时动态的),它根据任何最新的发展(如果有的话)重新审视这个问题可能是有意义的。因此,问题又是,&和下标的组合是否是获取指向数组的假想尾后元素的指针的有效方法inta[42]={};&a[42];它在C++98中被认为是未定义的。但是现代C++呢?我们已经看到DR#232,但出于某种原因仍处于“起草”状态,并且绝对不在标准文本中(自C++14起)。问题是否仍然悬而未决,还是已通过其他方式解决?有趣的是DR#315似乎公开允许通过空指针调用非静态成员函数p(!)基于“*p在p为空,除非左

c++ - constexpr lambda/‘x’ 没有命名类型;你是说 ‘x’ 吗?

我正在尝试使用C++17的constexprlambdas来获取编译时字符串:#includetemplatestructstr{constexprautooperator==(conststr&)const{returntrue;}voidfoo()const;};templateconstexprautomake_str(Ss,std::index_sequence){returnstr{};}#defineLIT(s)\make_str([](){returns;},std::make_index_sequence{})constexprautox=LIT("hansi");co